home
***
CD-ROM
|
disk
|
FTP
|
other
***
search
/
Amiga Plus 2000 #5
/
Amiga Plus CD - 2000 - No. 5.iso
/
Tools
/
Dev
/
GameboyDev
/
GBDK
/
examples
/
rpn.c
< prev
next >
Wrap
C/C++ Source or Header
|
1999-03-29
|
1KB
|
101 lines
#include <stdio.h>
#define MAXOP 40
#define NUMBER '0'
#define STACKSIZE 40
UBYTE sp;
WORD stack[STACKSIZE];
char s[MAXOP];
UBYTE pos;
WORD n;
void push(WORD l)
{
if(sp < STACKSIZE)
stack[sp++] = l;
else
puts("Stack full");
}
WORD pop()
{
if(sp > 0)
return stack[--sp];
else
puts("Stack empty");
return 0;
}
WORD top()
{
if(sp > 0)
return stack[sp-1];
else
puts("Stack empty");
return 0;
}
BYTE read_op()
{
if(pos == 0) {
gets(s);
}
while(s[pos] == ' ' || s[pos] == '\t')
pos++;
if(s[pos] == '\0') {
pos = 0;
return('\n');
}
if(!isdigit(s[pos]))
return(s[pos++]);
n = s[pos] - '0';
while(isdigit(s[++pos]))
n = 10 * n + s[pos] - '0';
return NUMBER;
}
void main()
{
BYTE type;
WORD op2;
puts("RPN Calculator");
sp = 0;
pos = 0;
while((type = read_op(s)) != 0) {
switch(type) {
case NUMBER:
push(n);
break;
case '+':
push(pop() + pop());
break;
case '*':
push(pop() * pop());
break;
case '-':
op2 = pop();
push(pop() - op2);
break;
case '/':
op2 = pop();
if(op2 != 0)
push(pop() / op2);
else
puts("Divide by 0");
break;
case '\n':
printf("==> %ld\n", top());
break;
}
}
}